.wrap {
  min-height: 100vh;
}

.header {
  background-color: #2d2d2d;
  text-align: center;

  display: flex;
  align-items: center;
  justify-content: center;

  & h1 {
    color: #fefefe;
    margin: 0;
  }
}

.main {
  background-color: #fefefe;
  color: #2d2d2d;
}

.footer {
  background-color: #3d3d3d;

  display: flex;
  align-items: center;
  justify-content: space-evenly;
  gap: max(1vw, 1vh);
  flex-wrap: wrap;

  * {
    color: #fefefe;
  }
}
